Railway track maintenance is a critical problem for any railway administrator. More precisely, preventive maintenance scheduling is an NP-hard problem, which additionally involves multiple 1 Peralta, October 25, 2017 objectives such as economical cost, maximum capacity, serviceability, safety and passenger comfort. This paper proposes a multi-objective optimization approach to this problem, combined with a track deterioration model that takes into account the degradation caused by maintenance operations. The track behavior is simulated by an exponential deterioration model based on a two-level segmentation. The maintenance schedule is built using a Pareto-based algorithm with two objectives (cost and delay) and three constraints, on top of an initialization heuristic based on expert knowledge. The proposed approach has been tested with two different algorithms (NSGA-II and AMOSA), over a model of a real track, to create schedules for different horizons ranging between three and twenty years. The solutions obtained by AMOSA outperform those designed by human experts both in terms of time delay and economical cost, demonstrating the capability of the proposal to produce near-optimal long-term maintenance schedules.